import { getStudentsByClassId } from '../../api/api.js';

Page({

    /**
     * 页面的初始数据
     */
    data: {
        classId: '',
        className: '',
        students: [],
        loading: true
    },

    /**
     * 生命周期函数--监听页面加载
     */
    onLoad(options) {
        const { classId, className } = options;

        this.setData({
            classId,
            className: className || '班级成员'
        });

        wx.setNavigationBarTitle({
            title: className ? `${className}的成员` : '班级成员'
        });

        this.loadStudents();
    },

    /**
     * 生命周期函数--监听页面初次渲染完成
     */
    onReady() {

    },

    /**
     * 生命周期函数--监听页面显示
     */
    onShow() {

    },

    /**
     * 生命周期函数--监听页面隐藏
     */
    onHide() {

    },

    /**
     * 生命周期函数--监听页面卸载
     */
    onUnload() {

    },

    /**
     * 页面相关事件处理函数--监听用户下拉动作
     */
    onPullDownRefresh() {
        this.loadStudents();
        wx.stopPullDownRefresh();
    },

    /**
     * 页面上拉触底事件的处理函数
     */
    onReachBottom() {

    },

    /**
     * 用户点击右上角分享
     */
    onShareAppMessage() {

    },

    /**
     * 加载学生列表
     */
    loadStudents() {
        const { classId } = this.data;

        this.setData({ loading: true });

        if (!classId) {
            this.setData({
                students: [],
                loading: false
            });
            return;
        }

        wx.showLoading({
            title: '加载中...',
        });

        getStudentsByClassId(classId)
            .then(res => {
                // 处理学生数据，添加状态信息
                const students = res.data.map((student) => ({
                    ...student,
                    studentId: student.id,
                    status: student.imageUrl ? "已注册" : "未注册",
                }));

                this.setData({
                    students,
                    loading: false
                });
                wx.hideLoading();
            })
            .catch(err => {
                console.error('获取学生列表失败:', err);
                wx.hideLoading();
                wx.showToast({
                    title: '加载失败',
                    icon: 'error'
                });
                this.setData({ loading: false });
            });
    },

    /**
     * 返回上一页
     */
    navigateBack() {
        wx.navigateBack();
    }
})